Application Serial No. 10/680,659 
LISTING OF THE CLAIMS 

1. (currently amended) A browser-based method for filling out an electronic 
form automatically without use of a stored map of said form, comprising the steps 
of: 

mapping said form by said browser based on analysis of at least one 
visible form element proximate at least one form field by analyzing text within a 
configurable area of a page containing said form, said page comprising an 
untransformed HTML page, said configurable area including configurable regions 
of said page at least above and below said field on said page , and 

populating said at least one form field with data retrieved according to said 
mapping a format specified by said mapping without user intervention in correct 
format without user intervention. 

2. (previously presented) The method of claim 1, wherein analyzing text 
expressions comprises the steps of: 

identifying fields based on analysis of visible field labels proximate said at 
least one field, when said field labels are present; and 

evaluating user visible display format hints proximate said fields to 
determine required display format. 

3. (previously presented) The method of claim 2, wherein said step of 
identifying fields based on analysis of visible field labels comprises: 

traversing form elements in a first sequence. 

4. (previously presented) The method of claim 3, wherein said step of 
identifying fields based on analysis of visible field labels further comprises any of 
the steps of: 

if a field is positioned in a table cell, analyzing text expressions in adjacent 

cells; 
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analyzing a text expression within a predetermined number of words and 
in at least one predetermined direction from said fields; 

based on page coordinates, examining said page in general vicinity of the 
field in all directions from the field and analyzing text expression closest to said 
field; and 

disregarding text expressions embedded within parentheses or quotation 

marks. 

5. (original) The method of claim 4, wherein said step of identifying fields 
based on analysis of visible field labels further comprises the step of: 

comparing the analyzed text expressions with entries in a field label 
dictionary to find closest match with a metadata expression, wherein said field is 
mapped to correct metadata. 

6. (original) The method of claim 3, further comprising the step of: 

when a field lacks a visible field label, mapping the field according to 
context. 

7. (original) The method of claim 6, wherein mapping the field according to 
context comprises: 

identifying mapping of at least one field preceding a current field in said 
first sequence; and 

mapping said current field based on said mapping of said preceding field. 

8. (original) The method of claim 3, further comprising the step of: 

when a field lacks a visible field label, mapping the field based on analysis 
of a programmatic field name. 

9. (original) The method of claim 3, further comprising the step of: 
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when a field lacks a visible field label, comparing the field's default value 
with entries in a field label dictionary to find closest match with a metadata 
expression, wherein said field is mapped to correct metadata. 

1 0. (original) The method of claim 3, further comprising the step of: 

if a field is a select field, comparing selection options with entries in a field 
label dictionary to find closest match with a metadata expression, wherein said 
field is mapped to correct metadata. 

1 1 . (original) The method of claim 3, further comprising the step of: 
for sets of radio buttons, creating a new object for each set. 

12. (original) The method of claim 3, further comprising the step of: 
identifying block type, wherein a block comprises a plurality of related 

fields. 

13. (original) The method of claim 12, wherein the step of identifying block 
type comprises one of the steps of: 

comparing programmatic field name of at least a current field with arrays 
of metadata expressions for each block type; 

comparing visible form elements for at least said current field with arrays 
of metadata expressions for each block type; and 

where said current field occupies a table cell, analyzing text expressions 
at least from first cell of said table to cell occupied by said current field. 

14. (previously presented) The method of claim 13, said step of identifying 
block type further comprising the step of: 

when a close match is found, mapping said field to said block type. 

15. (original) The method of claim 12, wherein block type includes any of: 
billing address; 
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shipping address; 

credit card information; and 

email address. 

1 6. (original) The method of claim 2, further comprising the step of: 
traversing form elements in a second sequence, said second sequence a 

reverse of a first sequence; 

identifying mapping of at least a field following a current field in said 
second sequence; and 

mapping said current field based on said mapping of said following field. 

17. (currently amended) The method of claim 2, wherein said step of 
evaluating visible display format hints proximate said fields to determine required 
display format comprises the steps of: 

traversing form elements in a first sequence; 
analyzing a visible display format hint proximate a field; 
comparing said analyzed display format hint with a dictionary of data-entry 
prompts; and 

mapping said field to a display format based on said comparison. 

18. (previously presented) The method of claim 17, further comprising the 
step of: 

any of concatenating, truncating and re-formatting said retrieved data 
according to said display format. 

19. (original) The method of claim 17, further comprising the step of: 

for a field lacking a proximate visible display format hint, mapping current 
field to same display format of a preceding field if both fields are the same field 
type. 
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20. (original) The method of claim 1, further comprising the step of: identifying 
a form as a checkout form. 

21 . (original) The method of claim 1 , further comprising the step of: 
masking confidential data from being displayed. 

22. (currently amended) A computer program product for filling out an 
electronic form automatically without use of a stored map of said form, said 
computer program product comprising a computer-readable medium having 
computer readable code embodied thereon, the computer code including 
program code means for: 

mapping said form by a browser based on analysis of at least one visible 
form element proximate a form filed by analyzing test expressions located within 
a configurable area of a page containing said form, said page comprising an 
untransformed HTML page, said configurable area including configurable regions 
of said page at least above and below said field, and 

populating said at least one form field by said browser with data retrieved 
according to said mapping in a format specified by said mapping without user 
intervention. 

23. (original) The computer program product of claim 22, wherein said code 
means for mapping said form based on analysis of visible form elements 
comprises code means for: 

identifying fields based on analysis of visible field labels proximate said 
fields, when said field labels are present; and 

evaluating user visible display format hints proximate said fields to 
determine required display format. 

24. (previously presented) The computer program product of claim 23, 
wherein said code means for identifying fields based on analysis of visible field 
labels comprises code means for: 
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traversing form elements in a first sequence. 

25. (previously presented) The computer program product of claim 24, 
wherein said code means for identifying fields based on analysis of visible field 
labels further comprises code means for any of: 

if a field is positioned in a table cell, analyzing text expressions in adjacent 

cells; 

analyzing a text expression within a predetermined number of words and 
in at least one predetermined direction from said fields; 

based on page coordinates, examining said page in general vicinity of the 
field in all directions from the field and analyzing text expression closest to said 
field; 

and disregarding text expressions embedded within parentheses or 
quotation marks. 

26. (original) The computer program product of claim 25, wherein said code 
means for identifying fields based on analysis of visible field labels further 
comprises code means for: 

comparing the analyzed text expressions with entries in a field label 
dictionary to find closest match with a metadata expression, wherein said field is 
mapped to correct metadata. 

27. (original) The computer program product of claim 24, further comprising 
code means for: 

when a field lacks a visible field label, mapping the field according to 
context. 

28. (original) The computer program product of claim 27, wherein said code 
means for mapping the field according to context comprises code means for: 

identifying mapping of at least one field preceding a current field in said 
first sequence; and 
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mapping said current field based on said mapping of said preceding field. 

29. (original) The computer program product of claim 24, further comprising 
code means for: 

when a field lacks a visible field label, mapping the field based on analysis 
of a programmatic field name. 

30. (original) The computer program product of claim 24, further comprising 
code means for: 

when a field lacks a visible field label, comparing the field's default value 
with entries in a field label dictionary to find closest match with a metadata 
expression, wherein said field is mapped to correct metadata. 

31. (original) The computer program product of claim 24, further comprising 
code means for: 

if a field is a select field, comparing selection options with entries in a field 
label dictionary to find closest match with a metadata expression, wherein said 
field is mapped to correct metadata. 

32. (original) The computer program product of claim 24, further comprising 
code means for: 

for sets of radio buttons, creating a new object for each set. 

33. (original) The computer program product of claim 24, further comprising 
code means for: 

identifying block type, wherein a block comprises a plurality of related 

fields. 

34. (original) The computer program product of claim 33, wherein the code 
means for identifying block type comprises code means for: 
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comparing programmatic field name of at least a current field with arrays 
of metadata expressions for each block type; 

comparing visible form elements for at least said current field with arrays 
of metadata expressions for each block type; and 

where said current field occupies a table cell, analyzing text expressions 
at least from a first cell of said table to a cell occupied by said current field. 

35. (original) The computer program product of claim 34, wherein the code 
means for identifying block type further comprises code means for: 

when a close match is found, mapping said field to said block type. 

36. (original) The computer program product of claim 33, wherein block type 
includes any of: 

billing address; 
shipping address; 
credit card information; and 
email address. 

37. (original) The computer program product of claim 23, further comprising 
code means for: 

traversing form elements in a second sequence, said second sequence a 
reverse of a first sequence; 

identifying mapping of at least a field following a current field in said 
second sequence; and 

mapping said current field based on said mapping of said following field. 

38. (original) The computer program product of claim 23, wherein said code 
means for evaluating visible display format hints proximate said fields to 
determine required display format comprises code means for: 

traversing form elements in a first sequence; 
analyzing a visible display format hint proximate a field; 
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comparing said analyzed display format hint with a dictionary of data-entry 
prompts; 

mapping said field to a display format based on said comparison. 

39. (previously presented) The computer program product of 38, further 
comprising the code means for: 

any of concatenating, truncating and re-formatting said retrieved data 
according to said display format. 

40. (original) The computer program product of claim 38, further comprising 
code means for: 

for a field lacking a proximate visible display format hint, mapping current 
field to same display format of a preceding field if both fields are the same field 
type. 

41. (original) The computer program product of claim 22, further comprising 
code means for: 

identifying a form as a checkout form. 

42. (original) The computer program product of claim 22, further comprising 
code means for: 

masking confidential data from being displayed. 

43. (currently amended) A client-based system for filling out an electronic form 
automatically without previously mapping or examining said form, comprising: 

a browser; 

at least one data file; 

rules for mapping visible form elements to correct data from said file; and 
computer-readable code means for: 

mapping said form by said browser based on analysis of at least 
one visible form element proximate at least one form field by analyzing 
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text expression located within a configurable area of a page containing 
said form said page comprising an untransformed HTML page, said 
configurable area including configurable regions of said page at least above and 
below said field ; and populating said at least one form field by said browser with 
data retrieved according to said mapping in a format specified by said mapping 
in correct format without user intervention; 

wherein said code is executable on a client running said browser, and 
wherein said rules, and said code are stored on said client. 

44. (original) The system of claim 43, wherein said code means for mapping 
said form based on analysis of visible form elements comprises code means for: 

identifying fields based on analysis of visible field labels proximate said 
fields, when said field labels are present; and 

evaluating user visible display format hints proximate said fields to 
determine required display format. 

45. (previously presented) The system of claim 44, wherein said code means 
for identifying fields based on analysis of visible field labels comprises code 
means for: 

traversing form elements in a first sequence. 

46. (previously presented) The system of claim 45, wherein said code means 
for identifying fields based on analysis of visible field labels further comprises 
code means for any of: 

if a field is positioned in a table cell, analyzing text expressions in adjacent 

cells; 

analyzing a text expression within a predetermined number of words and 
in at least one predetermined direction from said fields; 

based on page coordinates, examining said page in general vicinity of the 
field in all directions from the field and analyzing text expression closest to said 
field; and 
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disregarding text expressions embedded within parentheses or quotation 

marks. 

47. (original) The system of claim 46, wherein said code means for identifying 
fields based on analysis of visible field labels further comprises code means for: 

comparing the analyzed text expressions with entries in a field label 
dictionary to find closest match with a metadata expression, wherein said field is 
mapped to correct metadata. 

48. (original) The system of claim 45, further comprising code means for: 
when a field lacks a visible field label, mapping the field according to 

context. 

49. (original) The system of claim 48, wherein said code means for mapping 
the field according to context comprises code means for: 

identifying mapping of at least one field preceding a current field in said 
first sequence; and 

mapping said current field based on said mapping of said preceding field. 

50. (original) The system of claim 45, further comprising code means for: 
when a field lacks a visible field label, mapping the field based on analysis 

of a programmatic field name. 

51. (original) The system of claim 45, further comprising code means for: 
when a field lacks a visible field label, comparing the field's default value 

with entries in a field label dictionary to find closest match with a metadata 
expression, wherein said field is mapped to correct metadata. 

52. (original) The system of claim 45, further comprising code means for: 
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if a field is a select field, comparing selection options with entries in a field 
label dictionary to find closest match with a metadata expression, wherein said 
field is mapped to correct metadata. 

53. (original) The system of claim 45, further comprising code means for: 
for sets of radio buttons, creating a new object for each set. 

54. (original) The system of claim 24, further comprising code means for: 
identifying block type, wherein a block comprises a plurality of related 

fields. 

55. (original) The system of claim 54, wherein the code means for identifying 
block type comprises code means for: 

comparing programmatic field name of at least a current field with arrays 
of metadata expressions for each block type; 

comparing visible form elements for at least said current field with arrays 
of metadata expressions for each block type; and 

where said current field occupies a table cell, analyzing text expressions 
at least from first cell of said table to cell occupied by said current field. 

56. (original) The system of claim 55, wherein the code means for identifying 
block type further comprises code means for: 

when a close match is found, mapping said field to said block type. 

57. (original) The system of claim 54, wherein block type includes any of: 
billing address; 

shipping address; 

credit card information; and 

email address. 



Page 13 of 18 



Application Serial No. 10/680,659 

58. (currently amended) The system of claim 44, further comprising code 
means for: 

traversing form elements in a second sequence, said second sequence a 
reverse of a first sequence; 

identifying mapping of at least a field following a current field in said 
second sequence; and 

mapping said current field based on said mapping of said following field. 

59. (original) The system of claim 44, wherein said code means for evaluating 
visible display format hints proximate said fields to determine required display 
format comprises code means for: 

traversing form elements in a first sequence; 
analyzing a visible display format hint proximate a field; 
comparing said analyzed display format hint with a dictionary of data-entry 
prompts; 

mapping said field to a display format based on said comparison. 

60. (previously presented) The system of 59, further comprising code means 
for: any of concatenating, truncating and re-formatting said retrieved data 
according to said display format. 

61 . (original) The system of claim 59, further comprising code means for: 

for a field lacking a proximate visible display format hint, mapping current 
field to same display format of a preceding field if both fields are the same field 
type. 

62. (original) The system of claim 43, further comprising code means for: 
identifying a form as a checkout form. 

63. (original) The system of claim 43, further comprising code means for: 
masking confidential data from being displayed. 
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64. (original) The system of claim 43, wherein said data file resides on said 
client or on a server. 
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